# Chapter 7: Microarchitecture

# Pipelined Processor Hazards

# Pipelined Hazards

- When an instruction depends on result from instruction that hasn't completed
- Types:
  - Data hazard: register value not yet written back to register file
  - Control hazard: next instruction not decided yet (caused by branch)

## Data Hazard



# Handling Data Hazards

# Handling Data Hazards

- Insert enough nops for result to be ready
- Or move independent useful instructions forward



# Data Forwarding

- Data is available on internal busses before it is written back to the register file (RF).
- Forward data from internal busses to Execute stage.



# Data Forwarding

- Check if source register in Execute stage matches destination register of instruction in Memory or Writeback stage.
- If so, forward result.



# Data Forwarding: Hazard Unit



## Data Forwarding

- Case 1: Execute stage Rs1 or Rs2 matches Memory stage Rd?
   Forward from Memory stage
- Case 2: Execute stage Rs1 or Rs2 matches Writeback stage Rd? Forward from Writeback stage
- Case 3: Otherwise use value read from register file (as usual)

#### Equations for *Rs1*:

```
if ((Rs1E == RdM) \text{ AND } RegWriteM) // Case 1

ForwardAE = 10

else if ((Rs1E == RdW) \text{ AND } RegWriteW) // Case 2

ForwardAE = 01

else ForwardAE = 00 // Case 3
```

ForwardBE equations are similar (replace Rs1E with Rs2E)

# Data Forwarding

- Case 1: Execute stage Rs1 or Rs2 matches Memory stage Rd?
   Forward from Memory stage
- Case 2: Execute stage Rs1 or Rs2 matches Writeback stage Rd?
   Forward from Writeback stage
- Case 3: Otherwise use value read from register file (as usual)

#### Equations for Rs1:

```
if ((Rs1E == RdM) \text{ AND } RegWriteM) \text{ AND } (Rs1E != 0) // \text{ Case 1}
ForwardAE = 10
else if ((Rs1E == RdW) \text{ AND } RegWriteW) \text{ AND } (Rs1E != 0) // \text{ Case 2}
ForwardAE = 01
else ForwardAE = 00 // \text{ Case 3}
```

ForwardBE equations are similar (replace Rs1E with Rs2E)

# Data Hazard due to 1w Dependency



# Stalling to solve 1w Data Dependency



# Stalling Logic

 Is either source register in the Decode stage the same as the destination register in the Execute stage?

#### **AND**

Is the instruction in the Execute stage a lw?

```
|wStall| = ((Rs1D == RdE) \text{ OR } (Rs2D == RdE)) \text{ AND } ResultSrcE_0

|Stall| = |Stall| = |Stall| = |Stall|
```

(Stall the Fetch and Decode stages, and flush the Execute stage.)

# Stalling Hardware



# Chapter 7: Microarchitecture

# Pipelined Processor Control Hazards

## Control Hazards

## • beq:

- Branch not determined until the Execute stage of pipeline
- Instructions after branch fetched before branch occurs
- These 2 instructions must be flushed if branch happens

## Control Hazards



## **Branch misprediction penalty:**

The number of instructions flushed when a branch is taken (in this case, 2 instructions)

# Control Hazards: Flushing Logic

- If branch is taken in execute stage, need to flush the instructions in the Fetch and Decode stages
  - Do this by clearing Decode and Execute Pipeline registers using FlushD and FlushE

## • Equations:

```
FlushD = PCSrcE
FlushE = IwStall OR PCSrcE
```

# Control Hazards: Flushing Hardware



## RISC-V Pipelined Processor with Hazard Unit



# Summary of Hazard Logic

### Data hazard logic (shown for SrcA of ALU):

```
if ((Rs1E == RdM) \text{ AND } RegWriteM) \text{ AND } (Rs1E != 0) // Case 1

ForwardAE = 10

else if ((Rs1E == RdW) \text{ AND } RegWriteW) \text{ AND } (Rs1E != 0) // Case 2

ForwardAE = 01

else ForwardAE = 00 // Case 3
```

### Load word stall logic:

```
|wStall| = ((Rs1D == RdE) \text{ OR } (Rs2D == RdE)) \text{ AND } ResultSrcE_0

|StallF| = |StallD| = |wStall|
```

#### **Control hazard flush:**

```
FlushD = PCSrcE
FlushE = IwStall OR PCSrcE
```